<?xml version='1.0' encoding='UTF-8' ?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:ui="http://java.sun.com/jsf/facelets"
      xmlns:p="http://primefaces.org/ui"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:pe="http://primefaces.org/ui/extensions">

    <h:body>

        <ui:composition template="/resources/template/template.xhtml">

            <ui:define name="content">
                <h:form>


                    <p:panel header="Stock Report by Expiry" >
                        <h:panelGrid columns="3" styleClass="alignTop" >
                            <h:panelGrid columns="2" >
                                <h:outputLabel value="Department" ></h:outputLabel>
                                <p:autoComplete completeMethod="#{departmentController.completeDept}" var="dept" itemLabel="#{dept.name}" itemValue="#{dept}" forceSelection="true" value="#{reportsStock.department}" converter="departmentConverter" >
                                </p:autoComplete>
                                <h:outputLabel value="From" ></h:outputLabel>
                                <p:calendar value="#{reportsStock.fromDate}" pattern="dd MMM yyyy" ></p:calendar>
                                <h:outputLabel value="To" ></h:outputLabel>
                                <p:calendar value="#{reportsStock.toDate}" pattern="dd MMM yyyy" ></p:calendar>
                            </h:panelGrid>
                            <p:spacer width="20" height="1" ></p:spacer>
                            <h:panelGrid columns="1" >
                                <p:commandLink ajax="false" value="List Three Months Expiry" actionListener="#{reportsStock.fillThreeMonthsExpiary()}" ></p:commandLink>
                                <p:commandLink ajax="false" value="List Six Months Expiry" actionListener="#{reportsStock.fillSixMonthsExpiary()}" ></p:commandLink>
                                <p:commandLink ajax="false" value="List One Year Expiry" actionListener="#{reportsStock.fillOneYearExpiary()}" ></p:commandLink>
                            </h:panelGrid>
                        </h:panelGrid>
                        <h:panelGrid columns="3">
                            <p:commandButton ajax="false" value="Process" actionListener="#{reportsStock.fillDepartmentExpiaryStocks()}" ></p:commandButton>
                            <p:commandButton value="Print" ajax="false" >
                                <p:printer target="gpBillPreview" ></p:printer>
                            </p:commandButton>
                            <p:commandButton value="Excel" ajax="false">
                                <pe:exporter type="xlsx" target="tbl" fileName="Total Stock" />
                            </p:commandButton>
                        </h:panelGrid>

                        <h:panelGroup id="gpBillPreview"  styleClass="noBorder summeryBorder" style="min-width: 100%!important;">
                            <p:dataTable id="tbl" value="#{reportsStock.stocks}" var="i"  
                                         rows="20"
                                         paginator="true"
                                         paginatorTemplate="{CurrentPageReport}  {FirstPageLink} {PreviousPageLink} {PageLinks} {NextPageLink} {LastPageLink} {RowsPerPageDropdown}"
                                         rowsPerPageTemplate="10, 20, 50" >
                                <f:facet name="header">
                                    <h:outputLabel value="#{reportsStock.department.name} Stock"/>                                     
                                </f:facet>

                                <p:column headerText="Item"
                                          sortBy="#{i.itemBatch.item.name}"
                                          filterBy="#{i.itemBatch.item.name}"
                                          filterMatchMode="contains">
                                    <f:facet name="header">
                                        <h:outputLabel value="Item"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.item.name}" style="width: 100px!important;" ></h:outputLabel>
                                </p:column>

                                <p:column headerText="Code"
                                          sortBy="#{i.itemBatch.item.code}"
                                          filterBy="#{i.itemBatch.item.code}"
                                          filterMatchMode="contains"
                                          styleClass="averageNumericColumn"
                                          >
                                    <f:facet name="header">
                                        <h:outputLabel value="Code"/>
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.item.code}" style="width: 100px!important;" ></h:outputLabel>
                                </p:column>

                                <p:column headerText="Quantity" 
                                          style="text-align: right;"
                                          sortBy="#{i.stock}" styleClass="averageNumericColumn">
                                    <f:facet name="header">
                                        <h:outputLabel value="Quantity"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.stock}" styleClass="averateNumericText" >
                                        <f:convertNumber pattern="#,###" ></f:convertNumber>
                                    </h:outputLabel>                                 
                                </p:column>

                                <p:column headerText="Expiry"
                                          sortBy="#{i.itemBatch.dateOfExpire}"
                                          styleClass="averageNumericColumn">
                                    <f:facet name="header">
                                        <h:outputLabel value="Expiry"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.dateOfExpire}"  >
                                        <f:convertDateTime pattern="dd MMM yyyy" ></f:convertDateTime>
                                    </h:outputLabel>
                                </p:column>

                                <p:column headerText="Purchase Rate" 
                                          style="text-align: right;"
                                          styleClass="averageNumericColumn"
                                          sortBy="#{i.itemBatch.purcahseRate}">
                                    <f:facet name="header">
                                        <h:outputLabel value="Purchase Rate"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.purcahseRate}"  >
                                        <f:convertNumber pattern="#,##0.00" ></f:convertNumber>
                                    </h:outputLabel>

                                    <f:facet name="footer" >
                                        <h:outputLabel value="Total"/>                                       
                                    </f:facet>
                                </p:column>

                                <p:column headerText="Purchase Value" 
                                          styleClass="averageNumericColumn"
                                          style="text-align: right;"
                                          sortBy="#{i.itemBatch.purcahseRate * i.stock}">
                                    <f:facet name="header">
                                        <h:outputLabel value="Purchase Value"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.purcahseRate * i.stock}"  >
                                        <f:convertNumber pattern="#,##0.00" ></f:convertNumber>
                                    </h:outputLabel>
                                    <f:facet name="footer" >
                                        <h:outputLabel value="#{reportsStock.stockPurchaseValue}" >
                                            <f:convertNumber parent="#,##0.00" ></f:convertNumber>
                                        </h:outputLabel>
                                    </f:facet>
                                </p:column>

                                <p:column headerText="Retail Rate" 
                                          style="text-align: right;"
                                          styleClass="averageNumericColumn"
                                          sortBy="#{i.itemBatch.retailsaleRate}">
                                    <f:facet name="header">
                                        <h:outputLabel value="Retail Rate"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.retailsaleRate}"  >
                                        <f:convertNumber pattern="#,##0.00" ></f:convertNumber>
                                    </h:outputLabel>
                                </p:column>

                                <p:column headerText="Retail Sale Value" 
                                          style="text-align: right;"
                                          styleClass="averageNumericColumn"
                                          sortBy="#{i.itemBatch.retailsaleRate * i.stock}">
                                    <f:facet name="header">
                                        <h:outputLabel value="Retail Sale Value"/>                                     
                                    </f:facet>
                                    <h:outputLabel value="#{i.itemBatch.retailsaleRate * i.stock}"  >
                                        <f:convertNumber pattern="#,##0.00" ></f:convertNumber>
                                    </h:outputLabel>
                                    <f:facet name="footer" >
                                        <h:outputLabel value="#{reportsStock.stockSaleValue}" >
                                            <f:convertNumber parent="#,##0.00" ></f:convertNumber>
                                        </h:outputLabel>
                                    </f:facet>

                                </p:column>
                                <p:column headerText="Comments" 
                                          style="text-align: right;">
                                    <f:facet name="header">
                                        <h:outputLabel value="Comments"/>                                     
                                    </f:facet>
                                    <p:inputText value="#{i.code}" maxlength="254">
                                        <f:ajax event="blur" execute="@this" listener="#{reportsStock.addComment(i)}"></f:ajax>
                                    </p:inputText>
                                </p:column>


                                <p:columnGroup type="footer">
                                    <p:row>
                                        <p:column colspan="5" footerText="Total">
                                            <f:facet name="footer">
                                                <h:outputLabel value="Total" />
                                            </f:facet>
                                        </p:column>
                                        <p:column style="text-align: right;" footerText="#{reportsStock.stockPurchaseValue}">
                                            <f:facet name="footer" >
                                                <h:outputLabel value="#{reportsStock.stockPurchaseValue}" >
                                                    <f:convertNumber parent="#,##0.00" />
                                                </h:outputLabel>
                                            </f:facet>
                                        </p:column>
                                        <p:column></p:column>
                                        <p:column style="text-align: right;" footerText="#{reportsStock.stockSaleValue}">
                                            <f:facet name="footer" >
                                                <h:outputLabel value="#{reportsStock.stockSaleValue}" >
                                                    <f:convertNumber parent="#,##0.00" />
                                                </h:outputLabel>
                                            </f:facet>
                                        </p:column>
                                    </p:row>
                                    <p:row>
                                        <p:column colspan="9" >
                                            <f:facet name="footer" >
                                                <h:outputLabel value="Printed At " ></h:outputLabel>
                                                <h:outputLabel value="#{sessionController.currentDate}" >
                                                    <f:convertDateTime pattern="dd MMMM yyyy - hh:mm a" ></f:convertDateTime>
                                                </h:outputLabel>
                                            </f:facet>
                                        </p:column>
                                    </p:row>
                                </p:columnGroup>

                            </p:dataTable>


                        </h:panelGroup>
                    </p:panel>
                </h:form>


            </ui:define>


        </ui:composition>

    </h:body>
</html>
